

# XMICRO BUS Technical Specifications

# To Do:

- 1. Physical specifications
  - Connectors, orientation
  - o Backplane Dimensions
  - $\circ$  Card Dimensions, standard hole positions
  - o Distance to rear panel
- 2. Electrical Specifications
- 3. DMA system description
- 4.

#### Features:

8-bit Data Field Width
1 Megabyte Memory Address Range
Memory-mapped I/O
Asynchronous Data Transfer
Multiple Masters
Position Independence of Cards in Backplane
Automatic position-based Resource Allocation
Hardware Self-Discovery and Configuration
Main Memory Inhibit Signal
CPU Architecture Independence
ATX Power Supply Compatibility
Standard 62-pin Card Edge Connector
Fully Open-source

# **Functional Description**

# **Elements of a System**

An XMICRO system consists of the following elements:

- Backplane
- Primary Master
- · Secondary Masters
- Slaves

An XMICRO *Backplane* is the basis of any system. In its simplest form, the backplane handles power and signal distribution, and card-specific signal routing. Typically it should also include address-based card selection, signal combination circuitry for  $\overline{\text{CINH}}$  and  $\overline{\text{CBR}}$ , and a power-on reset circuit. More complex implementations may add significantly more functionality, including peripherals or an onboard primary master. When a primary master is built into a backplane, it should be referred to as a motherboard.

A *Primary Master* is a card or motherboard which acts as the default system controller. Typically this wil<u>l</u> be the main "CPU" card. In the context of this document, the "system controller" is the device driving the A<19..0>, READ, WRITE, and FETCH signals. Primary masters must default to this operation unless the bus is requested by another device. Only primary masters handle interrupt signals and bus requests.

A *Secondary Master* is a card with the ability to act as a temporary system controller. This is generally used for DMA operations by the secondary master, independent of the primary master.

A *Slave* is a card with no ability to control the system. Slaves are only capable of reading/writing data under the command of a master.

Note: The master/slave designation is somewhat loose and is used only as a broad classification of the functionality of a device. It may be used to refer to either a discrete subsystem or a card as a whole.

# Signal Lines

# Power Supply Rails (+12V, +5V, +5VSB +3.3V, GND, -12V)

These lines supply power to the bus. Current capacity is defined by the backplane's specifications, however it is not recomended to exceed 1.5A per card on any rail. If more current is required, an external power connection should be added to the card. Voltage tolerances match the ATX standard. It is recommended that a standard ATX power supply be used.

#### Address Lines (A<19..0>)

Twenty unidirectional lines driven by the master to specify a memory location.

# Data Lines (D<7..0>)

Eight bi-directional lines which carry information between master and slave devices.

# Read Strobe (RD)

Asserted by the master to indicate that the addressed slave device may place data on the data lines.

# Write Strobe (WR)

Asserted by the master to indicate that it has placed data on the data lines.

# Reset (RST)

This open-collector signal resets the system into a known state. During the power-on sequence, this signal should be asserted by the backplane for 500ms when the power supply becomes stable.



Figure 1: Bus Connector Pinout

# System Clock (CLK)

This signal is the main system clock. Care should be taken to ensure it is a clean square wave with a 50% duty cycle. Its frequency is undefined. The primary master should typically provide this signal, however it may optionally be provided by another card such as a video card. It is recommended that primary masters do not require externally generated clock signals to function.

#### **Auxilliary Clock (CLKAUX)**

This is a spare line intended for the synchronization of multiple cards requiring a clock source independent of the main system clock. Its use is unusual, so it is recommended that this signal be optional on any card using it.

#### Wait (WAIT)

This open-collector line is asserted to inform the master that the current data operation is not yet ready for completion. The master should wait until this signal is released to continue. Not to be confused with  $\overline{HALT}$ .

#### Halt (HALT)

This line is asserted by the primary master to indicate to that it is in a halted state and waiting for an interrupt. Not to be confused with WAIT.

#### Instruction Fetch (FETCH)

This signal is asserted by the primary master when the current data transfer operation is an instruction fetch.

#### Main Memory Inhibit (INH)

This slot-independent line is used to inhibit general-purpose main memory. When  $\overline{\text{INH}}$  is asserted, main memory must be prevented from reading or writing data, or driving the bus. This precludes the need for special hardware configuration when using devices requiring additional address space.

#### Bus Request (BUSRQ)

This slot-independent line is driven by a secondary master to request control of the bus. When the primary master is ready to release control of the bus, it will assert  $\overline{BUSACK}$ .

# Bus Acknowledge (BUSACK)

This signal is held low by the primary master to indicate that it has released the bus for control by a secondary master. The secondary master may only control the bus while this signal is asserted.

#### Card Select X (CSX)

This slot-specific signal is driven by the backplane to indicate that the current address is within the range of the slot's allocated address space. While this signal is asserted, A<19..8> may be ignored by the card because their state is known.

# Interrupt Request X (IRQX)

This slot-specific line is driven by a card to indicate that it requires the primary master's attention. It is routed to the appropriate input by the backplane. This allows for interrupt vectoring and prioritization based on card position. This is a level-triggered interrupt signal.

# Interrupt Request (IRQ<7..0>)

These eight lines are driven by cards through the IRQX line. They are used by the primary master for interrupt prioritization and vectoring. Under no circumstances are these lines to be driven directly by a card.

# Interrupt (INT)

This open-collector signal is used for special purposes where it is necessary to bypass a primary master's onboard interrupt handling circuitry. Typically this is only used to expand interrupt vectoring capabilities on backplanes with more than eight slots. Primary masters must accept this signal, either by including it in their interrupt handling scheme or combining it with the CPU's raw interrupt input. This is a level-triggered interrupt signal.

### Non-maskable Interrupt (NMI)

Edge-triggered interrupt signal. Its use is unusual, so it is recommended that this signal be optional on any card using it.

#### Combined Signals (CINH, CBR)

These two lines are the combined output of the each slot's  $\overline{\text{INH}}$  and  $\overline{\text{BUSRQ}}$  signals respectively. In testing it was found that open-collector signals did not exhibit fast enough performance to be used for the memory inhibit function. Instead, each card's  $\overline{\text{INH}}$  line is combined on the backplane using a high-speed AND to form the  $\overline{\text{CINH}}$  signal. The same is true of the  $\overline{\text{BUSRQ}}$  lines to form  $\overline{\text{CBR}}$ . The result is that the combined signal is asserted if any of the constituent signals is asserted. These signals are only used by devices *accepting* the  $\overline{\text{INH}}$  or  $\overline{\text{BUSRQ}}$  signals, such as memory cards or primary masters and shound only be driven by the combining circuit.

# **Electrical Specifications**

# **Signal Line Characteristics**

- A receiver must recognize a voltage of  $\leq$  0.8 V as a logic 0, and a voltage of  $\geq$  2.0 V as a logic 1.
- The minimum sink current capability of any driver on any line must be 24 mA at 0.5 V. Further, it is recommended that drivers with minimum source capability of 24 mA at 2.4 V be used.
- The minimum rise and fall transition times (10%-90%) of any line driving device must be > 5 ns when driving a capacitive load of 45 pF.
- The average current on any connector pin must not exceed 1A.